<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title>二级菜单</title>
    <style type="text/css">
        * {
            margin: 0;
            padding: 0;
            list-style-type: none;
        }

        a,img {
            border: 0;
            text-decoration: none;
        }

        body {
            font: 12px/180% Arial, Helvetica, sans-serif, "新宋体";
        }
    </style>

    <link rel="stylesheet" type="text/css" href="../css/sdmenu.css" />

    <script type="text/javascript" src="../js/tools.js"></script>
    <script type="text/javascript">
        window.onload = function(){
            //我们每一个菜单都是div 当div具有collapsed这个类时，div就是折叠状态
            //                     当div没有collapsed这个类时，div就是打开状态
            //点击菜单 切换菜单的显示状态
            var menuSpan=document.querySelectorAll(".menuSpan");//获取所有class为menuSpan的元素
            var openDIV=menuSpan[0].parentNode;
            for (var i=0;i<menuSpan.length;i++){//为span 绑定单击函数
                menuSpan[i].onclick=function () {
                    var parentDIV=this.parentNode;//获取当前span的父元素 this代表我当前要点击的span
                    toggleMenu(parentDIV);//切换菜单的显示状态
                    if (openDIV!=parentDIV&&!hasClass(openDIV,"collapsed")){//判断openDIV和parentDIV是否相同
                        //为了统一处理通话的过渡效果，所以我们将addClass改为toggleClass
                        // addClass(openDIV,"collapsed");//打开菜单后应该关闭之前打开的菜单
                        // toggleClass(openDIV,"collapsed");//toggleClass()此处不需要有移除的功能
                        toggleMenu(openDIV);//切换菜单的显示状态
                    }
                    openDIV=parentDIV;
                }
            }
            //用来切换菜单折叠和显示状态
            function toggleMenu(obj) {
                var begin=obj.offsetHeight;
                toggleClass(obj,"collapsed");//切换parentDIV的显示
                var end=obj.offsetHeight;
                // console.log("begin="+begin+",end="+end);
                //将元素的高度重置为height
                obj.style.height=begin+"px";
                //动画效果从begin到end过渡
                move(obj,"height",end,10,function () {
                    obj.style.height="";//动画执行完毕之后内联样式style:height 25没有任何意义了 需要删除
                })
            }
        };
    </script>

</head>

<body>

<div id="my_menu" class="sdmenu">
    <div>
        <span class="menuSpan">在线工具</span>
        <a href="#">图像优化</a>
        <a href="#">收藏夹图标生成器</a>
        <a href="#">邮件</a>
        <a href="#">htaccess密码</a>
        <a href="#">梯度图像</a>
        <a href="#">按钮生成器</a>
    </div>
    <div class="collapsed">
        <span class="menuSpan">支持我们</span>
        <a href="#">推荐我们</a>
        <a href="#">链接我们</a>
        <a href="#">网络资源</a>
    </div>
    <div class="collapsed">
        <span class="menuSpan">合作伙伴</span>
        <a href="#">JavaScript工具包</a>
        <a href="#">CSS驱动</a>
        <a href="#">CodingForums</a>
        <a href="#">CSS例子</a>
    </div>
    <div class="collapsed">
        <span class="menuSpan">测试电流</span>
        <a href="#">Current or not</a>
        <a href="#">Current or not</a>
        <a href="#">Current or not</a>
        <a href="#">Current or not</a>
    </div>
</div>
</body>
</html>